

This Page Is Inserted by IFW Operations  
and is not a part of the Official Record

## BEST AVAILABLE IMAGES

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images may include (but are not limited to):

- BLACK BORDERS
- TEXT CUT OFF AT TOP, BOTTOM OR SIDES
- FADED TEXT
- ILLEGIBLE TEXT
- SKEWED/SLANTED IMAGES
- COLORED PHOTOS
- BLACK OR VERY BLACK AND WHITE DARK PHOTOS
- GRAY SCALE DOCUMENTS

IMAGES ARE BEST AVAILABLE COPY.

**As rescanning documents *will not* correct images,  
please do not report the images to the  
Image Problems Mailbox.**

# PATENT ABSTRACTS OF JAPAN

(11)Publication number : 06-204897  
(43)Date of publication of application : 22.07.1994

(51)Int.CI. H03M 13/12  
H04L 25/08

(21)Application number : 04-349516 (71)Applicant : SONY CORP  
(22)Date of filing : 28.12.1992 (72)Inventor : YOSHIDA HIROYUKI  
YAMASHITA MASAMI

## (54) VITERBI DECODER

### (57)Abstract:

PURPOSE: To make high-speed operation possible and to prevent overflows without a problem in terms of speed by performing normalization by letting the most significant bit of the state metric of the time t+1 be '0' when it is decided that the normalization is performed based on the most significant bit of the values of all the state metric of the time (t) obtained by respective ACS circuits.

CONSTITUTION: The respective ACS circuits 1800–1807 add the pass metric before 1 symbol to branch metric BM10–BM11 inputted through terminal 11000–11010 and calculate the new pass metric corresponding to two passes. The pass metric values are compared, pass selecting signals SEL0–SEL7 for indicating the selected pass are outputted from the terminal 1110–1117 and also the selected pass metric is sent to the other ACS circuits 1800–1807. Also, a normalization detection circuit 170 for preventing the overflow performs the normalization for turning the MSB of the state metric SM0–SM7 of the time t+1 to '0' when it is decided that the normalization is performed.



## LEGAL STATUS

[Date of request for examination] 06.12.1999

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

[Date of registration]

[Number of appeal against examiner's decision of rejection]

[Date of requesting appeal against examiner's decision of rejection]

SOOP0047  
(99/082)

LSR

31151

(6)

(19)日本国特許庁 (JP)

(12) 公開特許公報 (A)

(11)特許出願公開番号

特開平6-204897

(43)公開日 平成6年(1994)7月22日

(51)Int.Cl.<sup>5</sup>  
H 03 M 13/12  
H 04 L 25/08

識別記号  
8730-5 J  
B 8226-5 K

F I

技術表示箇所

審査請求 未請求 請求項の数7(全12頁)

(21)出願番号 特願平4-349516

(22)出願日 平成4年(1992)12月28日

(71)出願人 000002185

ソニー株式会社

東京都品川区北品川6丁目7番35号

(72)発明者 吉田 洋之

東京都品川区北品川6丁目7番35号 ソニ  
ー株式会社内

(72)発明者 山下 雅美

東京都品川区北品川6丁目7番35号 ソニ  
ー株式会社内

(74)代理人 弁理士 小池 晃 (外2名)

(54)【発明の名称】 ビタビ復号器

(57)【要約】

【構成】 例えば拘束長K=4のビタビ復号器において、ステートメトリック計算部は、各ACS回路180<sub>0</sub>～180<sub>7</sub>で求めた時刻tの全ステートメトリックSM0～SM7のMSBに基づいて、ステートメトリックSMの正規化(オーバーフロウに対する補正)を行うか否かを決定する正規化検出回路170を有し、この回路170で正規化を行うと決定したときには時刻t+1のステートメトリックSM0～SM7のMSBを“0”にすることで正規化を行う。また、ACS回路180<sub>0</sub>～180<sub>7</sub>の加算器、セレクタは負論理構成とする。

【効果】 高速動作が可能となり、速度的に問題なくオーバーフロウの防止ができるようになる。また、構成の大型化を防止でき、IC化も容易となる。



## 【特許請求の範囲】

【請求項1】 入力符号に基づいてプランチメトリックを計算するプランチメトリック計算部と、プランチメトリックに基づいてバス選択信号を出力する複数のACS回路からなるステートメトリック計算部と、上記バス選択信号が供給される複数のバスメモリセルからなるバスメモリ回路と、上記バスメモリ回路の出力に対して最尤判定を行う最尤判定手段とを有するビタビ復号器において、

上記ステートメトリック計算部は、各ACS回路で求めた全ステートメトリック値の最上位ビットに基づいてステートメトリック値の正規化を行うか否かを決定することを特徴とするビタビ復号器。

【請求項2】 入力符号に基づいてプランチメトリックを計算するプランチメトリック計算部と、プランチメトリックに基づいてバス選択信号を出力する複数のACS回路からなるステートメトリック計算部と、上記バス選択信号が供給される複数のバスメモリセルからなるバスメモリ回路と、上記バスメモリ回路の出力に対して最尤判定を行う最尤判定手段とを有するビタビ復号器において、

上記ステートメトリック計算部は、時刻tのステートメトリック値に基づいてステートメトリック値の正規化を行うか否かを決定し、正規化すると決定したときには時刻t+1のステートメトリック値に対して正規化を行うことを特徴とするビタビ復号器。

【請求項3】 入力符号に基づいてプランチメトリックを計算するプランチメトリック計算部と、プランチメトリックに基づいてバス選択信号を出力する複数のACS回路からなるステートメトリック計算部と、上記バス選択信号が供給される複数のバスメモリセルからなるバスメモリ回路と、上記バスメモリ回路の出力に対して最尤判定を行う最尤判定手段とを有するビタビ復号器において、

上記ステートメトリック計算部は、ステートメトリック値の正規化を行うか否かを決定し、正規化すると決定したときには全ステートメトリック値の最上位ビットを“0”にすることで正規化を行うことを特徴とするビタビ復号器。

【請求項4】 入力符号に基づいてプランチメトリックを計算するプランチメトリック計算部と、プランチメトリックに基づいてバス選択信号を出力する複数のACS回路からなるステートメトリック計算部と、上記バス選択信号が供給される複数のバスメモリセルからなるバスメモリ回路と、上記バスメモリ回路の出力に対して最尤判定を行う最尤判定手段とを有するビタビ復号器において、

上記ステートメトリック計算部の各ACS回路は、プランチメトリックとステートメトリックとを加算する2つの加算器と、当該2つの加算器からの出力を比較する比

較器と、上記2つの加算器の出力を上記比較器の出力に基づいて選択するセレクタとを有してなると共に、上記加算器にはプランチメトリックとステートメトリックの加算時のオーバーフロウを防止するオーバーフロウ防止手段を設けることを特徴とするビタビ復号器。

【請求項5】 上記加算器は負論理構成とすることを特徴とする請求項4記載のビタビ復号器。

【請求項6】 上記ステートメトリック計算部は、プランチメトリックとステートメトリックとを加算する2つの加算器と、当該2つの加算器からの出力を比較する比較器と、上記2つの加算器の出力を上記比較器の出力に基づいて選択するセレクタとを有してなると共に、上記セレクタは負論理構成とすることを特徴とする請求項3記載のビタビ復号器。

【請求項7】 上記ステートメトリック計算部は、プランチメトリックとステートメトリックとを加算する2つの加算器と、当該2つの加算器からの出力を比較する比較器と、上記2つの加算器の出力を上記比較器の出力に基づいて選択するセレクタとを有してなると共に、上記セレクタ及び加算器は負論理構成とすることを特徴とする請求項3記載のビタビ復号器。

## 【発明の詳細な説明】

## 【0001】

【産業上の利用分野】 本発明は、畳み込み符号の最尤復号法に使用されるいわゆるビタビ復号器に関するものである。

## 【0002】

【従来の技術】 ビタビ(Viterbi)復号器は、畳み込み符号の最尤復号法に使用されるものであり、既知の複数個の符号系列のうち、入力符号系列に最も符号距離が近いパスを最尤パスとして選択し、この選択されたパスに対応して復号データを得るものであり、誤り訂正能力が高いことから例えば衛星通信等の復号器として使用されている。

【0003】 ここで、従来のビタビ復号器は、例えば図6に示すように、符号分配器としてのプランチメトリック計算部101と、複数のACS(Add Compare Select)回路からなるステートメトリック計算部102と、バスメモリ回路103と、上記バスメモリ回路103の出力に基づいて多数決を行って復号信号を得る多数決回路(最尤判定回路)104などで構成されるものである。

【0004】 すなわち、この図6において、上記符号分配器としてのプランチメトリック計算部101には、入力端子100<sub>1</sub>と100<sub>0</sub>を介した直交変調の復号信号I, Qが入力符号として供給されている。当該プランチメトリック計算部101では、これら入力符号から各ノード毎の4種類のプランチメトリック(ハミング距離)BM00～BM11を計算し、求めたプランチメトリックBM00～BM11を後段のステートメトリック計算部102の各ACS回路に送る。

【0005】ステートメトリック計算部102では、拘束長Kとすると、 $2^{k-1}$  状態分のステートメトリックが計算されると共に、 $2^{k-1}$  本のバス選択信号が出力される。ここで、ステートメトリック計算部102は、拘束長K=4とすると、例えば、図7に示すような複数のACS回路102<sub>0</sub>～102<sub>7</sub>からなるものである。

【0006】この図7において、上記各ACS回路102<sub>0</sub>～102<sub>7</sub>では、端子110<sub>00</sub>～110<sub>10</sub>を介して入力されたブランチメトリックBM00～BM11に1シンボル前のバスメトリックを加算して2つのバスに対応する新たなバスメトリックを計算し、これらのバスメトリック値を比較器で比較して、バスメトリックの小さい方を生き残りバスとして選択し、その選択したバスを示すバス選択信号（後段のバスメモリでのバス選択信号）SEL0～SEL7を端子111<sub>0</sub>～111<sub>7</sub>から出力すると共に、上記選択したバスメトリック（ステートメトリックSM0～SM7）を他のACS回路に送る。

【0007】また、このステートメトリック計算部102には、各ACS回路102<sub>0</sub>～102<sub>7</sub>におけるステートメトリックSM0～SM7の算出の際のオーバーフロウを防止するために、各ACS回路102<sub>0</sub>～102<sub>7</sub>で求めたステートメトリックSM0～SM7の値に基づいてオーバーフロウが発生するか否かを検出するオーバーフロウ検出回路としての正規化検出回路113が設けられている。当該正規化検出回路113では、各ステートメトリックSM0～SM7の値を見てオーバーフロウが発生すると検出したときには、当該ステートメトリックSM0～SM7の値に対するオーバーフロウの補正值（例えば減算値、すなわちステートメトリックの正規化情報）を求めて、この補正值（減算値）を各ACS回路102<sub>0</sub>～102<sub>7</sub>に送る。このとき、各ACS回路102<sub>0</sub>～102<sub>7</sub>では、上記ステートメトリックSM0～SM7の値に上記補正值を加算（すなわちステートメトリック値の減算、言い換えればステートメトリックの正規化）が行われるようになる。

【0008】ここで、各々のACS回路102<sub>0</sub>～102<sub>7</sub>は、具体的には例えば図8に示すように、加算器(Adder)122, 123と、比較器(Comparator)126と、セレクタ(Selector)127とを主要構成要素とするものである。

【0009】この図8において、1つのACS回路の端子120と121には1組のブランチメトリックBMが供給され、端子124と125には他のACS回路からの上記選択された1組のバスメトリック（ステートメトリックSM）が供給される。これらブランチメトリックBMとステートメトリックSMとがそれぞれ対応する加算器122, 123にて加算され、これら加算器122, 123からの出力（2つのバスに対応する新たなバスメトリック）が上記比較器126に送られる。当該比較器126では上記生き残りバスが選択され、そのバス

がバス選択信号（バス選択信号）SELとして端子129から出力される。また、上記加算器122, 123からのバスメトリックは上記セレクタ127にも送られ、当該セレクタ127では上記比較器126からのバス選択信号SELに基づいて上記2つのバスメトリックを選択する。

【0010】上記セレクタ127で選択されたバスメトリックはステートメトリックSMとして加算器116に送られると共に、端子114を介して上記オーバーフロウ防止のための正規化検出回路113にも送られる。当該正規化検出回路113では上記オーバーフロウが発生するか否かを検出して、オーバーフロウが発生すると検出した時には、上記ステートメトリックSMの値に基づいた上記補正值としての減算値を出力し、この減算値がACS回路の端子115を介して上記加算器116に送られる。すなわち、当該加算器116では、上記正規化検出回路113でオーバーフロウが発生すると検出されたときの上記減算値と、上記セレクタ127からのステートメトリックSMの値との加算（減算すなわち正規化）が行われる。この加算器116の出力がフリップフロップ（レジスタ）117を介して、他のACS回路へのステートメトリックSMとして端子128から出力される。

【0011】上記図8及び図7に示した各ACS回路からなる上記図6のステートメトリック計算部102からのバス選択信号（図7の各ACS回路からのバス選択信号）SEL0～SEL7は、バスメモリ回路103に送られる。当該バスメモリ回路103は、上記ステートメトリック計算部102からのバス選択信号SEL0～SEL7が、当該バスメモリ回路103の対応する各バスメモリセルに送られる。ここで、各段のバスメモリセルでは、入力データ（初段のバスメモリセルには初期値）が、クロックCLKと上記バス選択信号SEL0～SEL7に基づいて順次内部状態を遷移させるようにシフトされる。すなわち、復号サイクル毎にACS回路102<sub>0</sub>～102<sub>7</sub>で生き残りバスと判定した側のバスメモリセルの内容をバス選択信号を用いて後段のバスメモリセルに転送する。なお、拘束長Kの場合には、バスメモリセルが、状態数 $2^{k-1} \times$ 拘束長（K×5）個程度組み合わされてバスメモリ回路全体が構成される。

【0012】これらバスメモリセルからの出力が、図6の上記多数決回路（最尤判定回路）104に送られる。当該多数決回路104で判定された上記ステートメトリックSMが最小となる経歴のバスメモリ回路103の内容が“0”又は“1”的復号信号として出力端子105

から出力される。

【0013】なお、従来のビタビ復号器については、特開昭59-160349号公報や、特開昭60-111533号公報等に記載されているものを挙げることができる。

#### 【0014】

【発明が解決しようとする課題】ところで、上記ビタビ復号器のステートメトリック計算部の上述したような通常のACS回路においては、図7及び図8に示したように全てのACS回路 $102_0 \sim 102_7$ のセレクタ127の出力を正規化検出回路113に送り、当該正規化検出回路113でオーバーフロウを補正するための補正值を算出し、この補正值を各ACS回路 $102_0 \sim 102_7$ の加算器116に送って上記セレクタ127の出力値から減算して、新たなステートメトリックSMの値としてフリップフロップ117に記憶するようしている。

【0015】ここで、当該オーバーフロウの補正值検出(正規化検出)の動作は、1タイムスロット中で行われている。このようなことから、ステートメトリックSMの値に基づく補正值のフィードバックループが速度的に非常に困難となっている。

【0016】また、ビタビ復号器においては、符号の拘束長Kを大きくする程、誤り訂正能力が大きくなることから、当該誤り訂正能力を高めようとして拘束長Kを大きくしようとすると、拘束長Kのとき各ACS回路は $2^{K-1}$ 個必要となる。したがって、各ACS回路に対してオーバーフロウ防止のための構成(図8の加算器116等)を付加することは回路規模が大規模となり、好ましくない。

【0017】そこで、本発明は、上述のような実情に鑑みて提案されたものであり、構成の大型化を防止でき、速度的に問題なくオーバーフロウの防止ができ、さらに高速化も可能で、IC化も容易なステートメトリック計算部を有するビタビ復号器を提供することを目的とするものである。

#### 【0018】

【課題を解決するための手段】本発明のビタビ復号器は、上述の目的を達成するために提案されたものであり、入力符号に基づいてプランチメトリックを計算するプランチメトリック計算部と、プランチメトリックに基づいてバス選択信号を出力する複数のACS回路からなるステートメトリック計算部と、上記バス選択信号が供給される複数のバスメモリセルからなるバスメモリ回路と、上記バスメモリ回路の出力に対して最尤判定を行う最尤判定手段とを有するビタビ復号器であって、上記ステートメトリック計算部は、各ACS回路で求めた全ステートメトリック値の最上位ビット(MSB)に基づいてステートメトリック値の正規化(オーバーフロウに対する補正)を行うか否かを決定するようしている。

【0019】また、上記ステートメトリック計算部は、

時刻tのステートメトリック値に基づいてステートメトリック値の正規化(オーバーフロウに対する補正)を行うか否かを決定し、正規化すると決定したときには時刻t+1のステートメトリック値に対して正規化を行う。

【0020】さらに、上記ステートメトリック計算部は、ステートメトリック値の正規化(オーバーフロウに対する補正)を行うか否かを決定し、正規化すると決定したときには全ステートメトリック値の最上位ビットを“0”にすることで正規化を行う。

【0021】なお、上記ステートメトリック値の正規化を行うか否かを決定する具体的手段(正規化検出手段)としては、各ステートメトリック値のMSBが各入力端子に供給されるAND(論理積)ゲートを例に挙げることができる。すなわち、当該正規化検出手段としてのANDゲートの各入力端子に供給される各ステートメトリックのMSBが全て“1”となったときには、オーバーフロウが発生する虞れがある。したがって、当該ANDゲートの各入力端子への上記ステートメトリックのMSBが全て“1”となったときの当該ANDゲートの出力端子からの“1”的出力を、オーバーフロウの補正值(検出値)として各ACS回路に送る。

【0022】ここで、上記ステートメトリック計算部の各ACS回路は、プランチメトリックとステートメトリックとを加算する2つの加算器と、当該2つの加算器からの出力を比較する比較器と、上記2つの加算器の出力を上記比較器の出力に基づいて選択するセレクタとをしてなる。

【0023】上記加算器にはプランチメトリックとステートメトリックの加算時のオーバーフロウを防止するオーバーフロウ防止手段を設けることができる。また、当該加算器及び/又はセレクタには負論理のゲート回路を用いることができる。

#### 【0024】

【作用】本発明のビタビ復号器によれば、正規化を行うタイミングが、正規化決定時の1タイムスロット後に実施されるため、フィードバックループの外で並列処理でき、高速動作が可能となる。

#### 【0025】

【実施例】以下、本発明の実施例を図面を参照しながら説明する。

【0026】本発明の実施例のビタビ復号器は、例えば前述した図6のように、入力符号に基づいてプランチメトリックBMを計算するプランチメトリック計算部と、プランチメトリックBMに基づいてバス選択信号(バス選択信号)SELを出力する複数のACS回路からなるステートメトリック計算部と、上記バス選択信号SELが供給される複数のバスメモリセルからなるバスメモリ回路と、上記バスメモリ回路の出力に対して最尤判定を行なう最尤判定手段としての多数決回路とを有するビタビ復号器であって、上記ステートメトリック計算部は、図

1に示すように、各ACS回路 $180_0 \sim 180_7$ で求めた時刻tの全ステートメトリックSM0～SM7の値の最上位ビット(MSB)に基づいて、ステートメトリック値の正規化(オーバーフロウに対する補正)を行うか否かを決定する正規化検出回路170を設け、当該正規化検出回路170で正規化を行うと決定したときには時刻t+1のステートメトリックSM0～SM7の最上位ビット(MSB)を“0”にすることで正規化を行うようにしたものである。

【0027】なお、この図1には、拘束長K=4の場合を例に挙げている。また、図1と前述の図7とで対応する部分には同一の指示符号を付している。

【0028】すなわち、この図1において、上記各ACS回路 $180_0 \sim 180_7$ では、端子 $110_{00} \sim 110_{10}$ を介して入力されたブランチメトリックBM00～BM11に1シンボル前のバスメトリックを加算して2つのバスに対応する新たなバスメトリックを計算し、これらのバスメトリック値を比較器で比較して、バスメトリックの小さい方を生き残りバスとして選択し、その選択したバスを示すバス選択信号SEL0～SEL7を端子 $111_0 \sim 111_7$ から出力すると共に、上記選択したバスメトリック(ステートメトリックSM0～SM7)を他のACS回路に送る。

【0029】また、本実施例のこのステートメトリック計算部には、各ACS回路 $180_0 \sim 180_7$ におけるステートメトリックSM0～SM7の算出の際のオーバーフロウを防止するために、上記オーバーフロウ検出回路としての正規化検出回路170が設けられている。当該正規化検出回路170では、上述したように、時刻tの全ステートメトリックSM0～SM7の値のMSBに基づいて上記正規化を行うか否かを決定し、正規化を行うと決定したときには時刻t+1のステートメトリックSM0～SM7のMSBを“0”にする正規化を行うための正規化検出出力(補正值、減算値)を各ACS回路 $180_0 \sim 180_7$ に送る。

【0030】ここで、各々のACS回路 $180_0 \sim 180_7$ は、具体的には例えば図2に示すように、加算器(Adder)220, 230と、比較器(Comparator)126と、セレクタ(Selector)200とを主要構成要素とするものである。なお、この図2においても、前述した図8と同様の部分には同一の指示符号を付している。

【0031】この図2において、1つのACS回路の端子120と121にはブランチメトリック計算部からの1組のブランチメトリックBMが供給され、端子124と125には他のACS回路からの上記選択された1組のバスメトリックが供給される。これらブランチメトリックBMとステートメトリックSMとがそれぞれ対応する加算器220, 230にて加算される。

【0032】例えば、上記ステートメトリックSMが7ビット長(s<sub>m0</sub>～s<sub>m6</sub>の7ビット)で構成され、上

記ブランチメトリックBMが4ビット長(b<sub>m0</sub>～b<sub>m3</sub>の4ビット)で構成されるとすると、上記加算器220, 230は、例えば図3に示すように、加算演算の主要構成要素として、1個の4ビット全加算器224<sub>03</sub>と3個の半加算器224<sub>4</sub>～224<sub>6</sub>とを有してなるものである。

【0033】この図3において、端子221には上記ステートメトリックSMの各ビットs<sub>m0</sub>～s<sub>m6</sub>が供給され、当該各ビットs<sub>m0</sub>～s<sub>m6</sub>のうちの下位側4ビットs<sub>m0</sub>～s<sub>m3</sub>は上記4ビット全加算器224<sub>03</sub>の対応する入力端子A<sub>0</sub>～A<sub>3</sub>に送られる。また、ステートメトリックSMの上位側3ビットs<sub>m4</sub>～s<sub>m6</sub>はそれぞれ対応する半加算器224<sub>4</sub>～224<sub>6</sub>の入力端子A<sub>0</sub>に送られる。また、端子222には上記ブランチメトリックBMの各ビットb<sub>m0</sub>～b<sub>m3</sub>が供給され、上記4ビット全加算器224<sub>03</sub>の対応する入力端子B<sub>0</sub>～B<sub>3</sub>に送られる。

【0034】上記4ビット全加算器224<sub>03</sub>では、上記ステートメトリックSMの下位側4ビットs<sub>m0</sub>～s<sub>m3</sub>とブランチメトリックの各ビットb<sub>m0</sub>～b<sub>m3</sub>との加算を行い、各出力端子S<sub>0</sub>～S<sub>3</sub>から加算結果が出力され、桁上げがある場合にはキャリアアウト端子C<sub>0</sub>から桁上げ信号(キャリアアウト信号)が出力される。

【0035】上記4ビット全加算器224<sub>03</sub>のキャリアアウト端子C<sub>0</sub>は、上記半加算器224<sub>4</sub>の入力端子B<sub>0</sub>と接続されている。また、当該半加算器224<sub>4</sub>のキャリアアウト端子C<sub>0</sub>は半加算器224<sub>5</sub>の入力端子B<sub>0</sub>と接続され、さらに当該半加算器224<sub>5</sub>のキャリアアウト端子C<sub>0</sub>は半加算器224<sub>6</sub>の入力端子B<sub>0</sub>と接続されている。これら半加算器224<sub>4</sub>～224<sub>6</sub>における加算結果は、各々の出力端子Sから出力される。

【0036】すなわち、この図3の加算器においては、上記全加算器224<sub>03</sub>及び半加算器224<sub>4</sub>～224<sub>6</sub>によって、全体でステートメトリックSMとブランチメトリックBMの加算を実現している。

【0037】また、当該図3に示す加算器には、ステートメトリックSMとブランチメトリックBMとの上記加算結果がオーバーフロウしないようにするためのオーバーフロウ防止手段としての1個の4入力ANDゲート223及び7個の2入力NORゲート225<sub>0</sub>～225<sub>6</sub>を設けている。すなわち、ステートメトリックSMが7ビット長でブランチメトリックBM wビット長の場合においては、7ビット+4ビット=8ビットとなる場合があるため、上記加算結果が7ビット長を越えないように(端子226からの出力q<sub>0</sub>～q<sub>6</sub>が7ビット長を越えないように)するために、上記ANDゲート223及びNORゲート225<sub>0</sub>～225<sub>6</sub>を設けている。上記ANDゲート223の4つの入力端子には、上記4ビット全加算器224<sub>03</sub>のキャリアアウト信号と上記上位側3ビットのステートメトリックs<sub>m4</sub>, s<sub>m5</sub>, s<sub>m6</sub>の

各ビットが供給されるようになっている。また、上記7つのNORゲート $225_0 \sim 225_6$ のうちのゲート $225_0 \sim 225_3$ のそれぞれ一方の入力端子には上記4ビット全加算器 $224_{03}$ の対応する各出力端子S $0 \sim S_3$ から加算結果が供給され、ゲート $225_4 \sim 225_6$ のそれぞれ一方の入力端子には対応する半加算器 $224_4 \sim 224_6$ の各出力端子Sから加算結果が供給されるようになっている。

【0038】ここで、図3に示した構成において、7ビット長のステートメトリックSMと4ビット長のブランチメトリックBMとを加算した結果が8ビット長になる場合すなわちオーバーフロウするのは、必ず、上記4ビット全加算器 $224_{03}$ のキャリアアウト信号と、上記上位側3ビットのステートメトリックsm4, sm5, sm6の各ビットとが“1”となる場合のみである。

【0039】このため、本実施例では、上記4入力ANDゲート $223$ で上記4ビット全加算器 $224_{03}$ のキャリアアウト信号と上記上位側3ビットのステートメトリックsm4, sm5, sm6の各ビットの論理積(AND)を取るようにし、上記4ビット全加算器 $224_{03}$ のキャリアアウト信号と上記上位側3ビットのステートメトリックsm4～sm6が全て“1”となった場合の当該4入力ANDゲート $223$ の出力(すなわち“1”)を、上記7個のNORゲート $225_0 \sim 225_6$ のそれぞれ他方の入力端子に送るようにしている。これにより、上記4入力ANDゲート $223$ の出力が“1”的場合(すなわちオーバーフロウする場合)には、各NORゲート $225_0 \sim 225_6$ から“0”が出力されるようになりオーバーフロウが防止されるようになる。なお、オーバーフロウがない場合すなわち4入力ANDゲート $223$ の出力が“0”的場合は、上記全加算器 $224_{03}$ 及び半加算器 $224_4 \sim 224_6$ の加算出力が全て反転出力となって、端子 $226$ から出力(7ビット出力q $0 \sim q_6$ )されるようになる。

【0040】このように、本実施例の図3の加算器においては、上記半加算器 $224_4 \sim 224_6$ における3ビット分の加算を行う前に、オーバーフロウを行うか否かが判定できるので、処理の高速化が可能となる。

【0041】また、本実施例の図3の加算器において、各NORゲート $225_0 \sim 225_6$ はORゲートとすることも可能であるが、負論理構成とするとゲート数を削減することができると共にその分処理も高速化できるので、本実施例では負論理の上記NORゲート $225_0 \sim 225_6$ を用いるようにしている。

【0042】図2に戻って、上述したような図3の構成の加算器 $220, 230$ からのバスメトリックが上記比較器 $126$ に送られる。当該比較器 $126$ では生き残りバスが選択され、そのバスがバス選択信号(バス選択信号)SELとして端子 $129$ から出力される。また、上記加算器 $122, 123$ からのバスメトリックは上記セ

レクタ $200$ にも送られ、当該セレクタ $200$ では上記比較器 $126$ からのバス選択信号SELに基づいて上記2つのバスメトリックを選択する。

【0043】上記セレクタ $200$ で選択されたバスメトリックはステートメトリックSMとしてフリップフロップ $177$ に送られ記憶される。このフリップフロップ $177$ からの1タイムクロック前のステートメトリックSMは、端子 $128$ から出力されて他のACS回路に送られると共に、当該1タイムクロック前の全ステートメトリックSMのMSBのみが上記正規化検出回路 $170$ に送られる。

【0044】当該正規化検出回路 $170$ は、具体的には図4及び図1に示すように、n入力(拘束長Kの場合は $n = 2^{K-1}$ で、本実施例では拘束長K=4であるため7入力)のANDゲート $172$ からなるものである。

【0045】図4において、当該正規化検出回路 $170$ の端子 $174_0 \sim 174_n$ (本実施例では端子 $174_0 \sim 174_7$ )には、上記ステートメトリックSM $0 \sim S_7$ のMSBが供給され、ANDゲート $172$ に送られる。当該ANDゲート $172$ ではn個(7個)のステートメトリックSM $0 \sim S_7$ のMSBの全ての論理積を取り、その出力を正規化検出出力norとして端子 $173$ から出力する。すなわち、当該正規化検出回路 $170$ においては、n個(7個)のステートメトリックSM $0 \sim S_7$ のMSBビットが全て“1”となった時に“1”となる正規化検出出力norを、端子 $173$ を介して各ACS回路 $180_0 \sim 180_7$ に対して送る。言い換えれば、当該正規化検出回路 $170$ のANDゲート $172$ の各入力端子に供給される各ステートメトリックSMのMSBが全て“1”となったときには、オーバーフロウが発生する虞れがあるので、当該ANDゲート $172$ の各入力端子への上記ステートメトリックSMのMSBが全て“1”となったときの当該ANDゲート $172$ の出力端子からの“1”的出力を、オーバーフロウの補正值として各ACS回路 $180_0 \sim 180_7$ に送り、これらACS回路 $180_0 \sim 180_7$ で正規化を行うようさせる。なお、オーバーフロウしない時すなわち正規化を行わない時には上記正規化検出出力norは“0”である。

【0046】ここで、上記正規化検出出力norは、図2に示すように、各ACS回路 $180_0 \sim 180_7$ の端子 $171$ を介して、セレクタ $200$ に送られるようになっている。

【0047】当該セレクタ $200$ は、具体的には図5に示すように構成されるものである。この図5において、上記ステートメトリックSMを7ビット長とした場合、当該セレクタ $200$ の端子 $202$ には、前述した図2の加算器 $220, 230$ の何れか一方からの7ビットの加算出力a $0 \sim a_7$ が供給され、端子 $203$ には他方の加算器からの7ビットの加算出力b $0 \sim b_7$ が供給され

る。また、端子201には上記正規化検出出力n<sub>o</sub>rが供給されるようになっており、端子204にはバス選択信号SELが供給される。

【0048】上記加算出力a<sub>0</sub>～a<sub>7</sub>のうちのa<sub>0</sub>はANDゲート205<sub>0</sub>の一方の入力端子に送られ、上記加算出力b<sub>0</sub>～b<sub>7</sub>のうちのb<sub>0</sub>はANDゲート206<sub>0</sub>の一方の入力端子に送られる。以下同様に、加算出力a<sub>1</sub>はANDゲート205<sub>1</sub>の一方の入力端子に、上記加算出力b<sub>1</sub>はANDゲート206<sub>1</sub>の一方の入力端子に、加算出力a<sub>2</sub>はANDゲート205<sub>2</sub>の一方の入力端子に、上記加算出力b<sub>2</sub>はANDゲート206<sub>2</sub>の一方の入力端子に、加算出力a<sub>3</sub>はANDゲート205<sub>3</sub>の一方の入力端子に、上記加算出力b<sub>3</sub>はANDゲート206<sub>3</sub>の一方の入力端子に、加算出力a<sub>4</sub>はANDゲート205<sub>4</sub>の一方の入力端子に、上記加算出力b<sub>4</sub>はANDゲート206<sub>4</sub>の一方の入力端子に、加算出力a<sub>5</sub>はANDゲート205<sub>5</sub>の一方の入力端子に、上記加算出力b<sub>5</sub>はANDゲート206<sub>5</sub>の一方の入力端子に、加算出力a<sub>6</sub>はANDゲート205<sub>6</sub>の一方の入力端子に、上記加算出力b<sub>6</sub>はANDゲート206<sub>6</sub>の一方の入力端子に送られる。

【0049】また、これら各ANDゲート205<sub>0</sub>～205<sub>6</sub>のそれぞれ他方の入力端子には上記バス選択信号SELが供給され、各ANDゲート206<sub>0</sub>～206<sub>6</sub>のそれぞれ他方の入力端子にはインバータ209を介して反転されたバス選択信号SELが供給されるようになっている。

【0050】さらに、これら各ANDゲート205<sub>0</sub>～205<sub>6</sub>及び206<sub>0</sub>～206<sub>6</sub>の各出力は、それぞれ対応するNORゲート207<sub>0</sub>～207<sub>6</sub>の入力端子に送られる。すなわち、ANDゲート205<sub>0</sub>の出力はNORゲート207<sub>0</sub>の一方の入力端子に、ANDゲート206<sub>0</sub>の出力はNORゲート207<sub>0</sub>の他方の入力端子に送られる。以下同様に、ANDゲート205<sub>1</sub>の出力はNORゲート207<sub>1</sub>の一方の入力端子に、ANDゲート206<sub>1</sub>の出力はNORゲート207<sub>1</sub>の他方の入力端子に、ANDゲート205<sub>2</sub>の出力はNORゲート207<sub>2</sub>の一方の入力端子に、ANDゲート206<sub>2</sub>の出力はNORゲート207<sub>2</sub>の他方の入力端子に、ANDゲート205<sub>3</sub>の出力はNORゲート207<sub>3</sub>の一方の入力端子に、ANDゲート206<sub>3</sub>の出力はNORゲート207<sub>3</sub>の他方の入力端子に、ANDゲート205<sub>4</sub>の出力はNORゲート207<sub>4</sub>の一方の入力端子に、ANDゲート206<sub>4</sub>の出力はNORゲート207<sub>4</sub>の他方の入力端子に、ANDゲート205<sub>5</sub>の出力はNORゲート207<sub>5</sub>の一方の入力端子に、ANDゲート206<sub>5</sub>の出力はNORゲート207<sub>5</sub>の他方の入力端子に、ANDゲート205<sub>6</sub>の出力はNORゲート207<sub>6</sub>の一方の入力端子に、ANDゲート206<sub>6</sub>の出力はNORゲート207<sub>6</sub>の他方の入力端子に送られ

る。

【0051】したがって、これら各ANDゲート205<sub>0</sub>～205<sub>6</sub>と206<sub>0</sub>～206<sub>6</sub>及びNORゲート207<sub>0</sub>～207<sub>6</sub>においては、上記バス選択信号SEL及びその反転信号に応じてそれぞれ上記加算出力a<sub>0</sub>～a<sub>7</sub>とb<sub>0</sub>～b<sub>7</sub>の選択がなされる。例えば、上記バス選択信号SELが“0”的時は上記加算出力b<sub>0</sub>～b<sub>6</sub>が選択され、上記バス選択信号SELが“1”的時は上記加算出力a<sub>0</sub>～a<sub>6</sub>が選択される。

【0052】ところで、この図5に示すセレクタにおいて、上記NORゲート207<sub>6</sub>は3入力となっており、当該NORゲート207<sub>6</sub>の3番目の入力端子には上記端子201を介する上記正規化検出出力n<sub>o</sub>rが供給されるようになっている。

【0053】すなわち、この図5に示す本実施例のセレクタにおいては、上記加算出力a<sub>0</sub>～a<sub>7</sub>とb<sub>0</sub>～b<sub>7</sub>の最上位ビットに対応する上記NORゲート207<sub>6</sub>に對して上記正規化検出出力n<sub>o</sub>rを送ることで、選択と同時に正規化すなわちオーバーフロウの補正を可能としている。

【0054】具体的に言うと、上記正規化検出出力n<sub>o</sub>rが“1”となる場合（オーバーフロウする場合）には、MSBビット（図5の場合は第6ビット）を除く（第0～第5ビット）については通常通り選択出力されるが、MSBビットは上記正規化検出出力n<sub>o</sub>rが供給される上記NORゲート207<sub>6</sub>におけるNOR論理により、出力Q<sub>6</sub>は“0”になる。ここで、当該正規化検出出力n<sub>o</sub>rは、全ACS回路（図1のACS回路180<sub>0</sub>～180<sub>7</sub>）に接続されているため、全ステートメトリックSM0～SM7のMSBビットは“0”になり、これにより正規化が可能となる。

【0055】なお、本実施例の図5のセレクタにおいても、各NORゲート207<sub>0</sub>～207<sub>6</sub>はORゲートとすることも可能であるが、負論理構成とするとゲート数を削減することができると共にその分処理も高速化できるので、本実施例では負論理の上記NORゲート207<sub>0</sub>～207<sub>6</sub>を用いるようにしている。また、本実施例では、前述した図3のように、加算器で負論理構成を用いているので、当該セレクタでも負論理構成とすることで、当該セレクタの出力は正論理に直すことができる。

【0056】上述した各ACS回路180<sub>0</sub>～180<sub>7</sub>の図5に示したセレクタ200の出力Q<sub>0</sub>～Q<sub>6</sub>（ステートメトリックSM）は、出力端子210から出力され、図2のフリップフロップ177に送られる。

【0057】上述したように、本実施例においては、全体として、時刻tにおける全ステートメトリックSMから正規化を検出し、時刻t+1に正規化を実施することにより、また、正規化の判定は全ステートメトリックSMのMSBビットに対して行い、この検出出力に基づいて正規化を行うことによって、高速動作かつ小規模の回

路で実現できるようになった。

【0058】すなわち、本発明実施例のビタビ復号器によれば、正規化を行うタイミングが、正規化決定時の1タイムスロット後に実施されるため、フィードバックループの外で並列処理でき、高速動作が可能となる。したがって、特に、拘束長Kが長い場合に適用すると、回路規模の増大を抑えることができ、I C化する上で非常に有利となる。

(0059)

【発明の効果】 上述のように、本発明においては、ステートメトリック計算部は、各ACS回路で求めた時刻tの全ステートメトリックの値の最上位ビットに基づいて、ステートメトリック値の正規化（オーバーフロウに対する補正）を行うか否かを決定し、正規化を行うと決定したときには時刻t+1のステートメトリックの最上位ビットを“0”にすることで正規化を行うようにしたことにより、正規化を行うタイミングが、正規化決定時の1タイムスロット後に実施されるようになって FIFOバックループの外で並列処理でき高速動作が可能となり、速度的に問題なくオーバーフロウの防止ができるようになる。また、ステートメトリック計算部のACS回路の加算器及びセレクタを負論理構成とすることで、構成の大型化を防止でき、さらに高速化も可能で、IC化も容易となる。

### 【図面の簡単な説明】

【図1】本発明の実施例の拘束長K=4のビタビ復号器のステートメトリック計算部の概略構成を示すブロック回路図である。

【図2】本実施例のステートメトリック計算部のACS回路及び正規化検出回路の概略構成を示すブロック回路図である。

[図2]



〔图4〕



【図1】



【図7】



【図3】



【図5】



〔図6〕



〔図8〕

